<script lang="ts" setup>
import type { MallMemberStatisticsApi } from '#/api/mall/statistics/member';

import { onMounted, ref } from 'vue';

import { DocAlert, Page, SummaryCard } from '@vben/common-ui';
import { fenToYuan } from '@vben/utils';

import { Col, Row } from 'ant-design-vue';

import { getMemberSummary } from '#/api/mall/statistics/member';

import MemberAreaCard from './modules/area-card.vue';
import MemberFunnelCard from './modules/funnel-card.vue';
import MemberSexCard from './modules/sex-card.vue';
import MemberTerminalCard from './modules/terminal-card.vue';

/** 会员统计 */
defineOptions({ name: 'MemberStatistics' });

const loading = ref(true); // 加载中
const summary = ref<MallMemberStatisticsApi.Summary>(); // 会员统计数据

/** 查询会员统计 */
async function loadMemberSummary() {
  summary.value = await getMemberSummary();
}

/** 初始化 */
onMounted(async () => {
  loading.value = true;
  try {
    await loadMemberSummary();
  } finally {
    loading.value = false;
  }
});
</script>

<template>
  <Page auto-content-height>
    <template #doc>
      <DocAlert
        title="【统计】会员、商品、交易统计"
        url="https://doc.iocoder.cn/mall/statistics/"
      />
    </template>

    <div class="flex flex-col gap-4">
      <!-- 统计卡片 -->
      <Row :gutter="16">
        <Col :md="6" :sm="12" :xs="24">
          <SummaryCard
            title="累计会员数"
            :value="summary?.userCount || 0"
            icon="fa-solid:users"
            icon-color="text-blue-500"
            icon-bg-color="bg-blue-100"
          />
        </Col>
        <Col :md="6" :sm="12" :xs="24">
          <SummaryCard
            title="累计充值人数"
            :value="summary?.rechargeUserCount || 0"
            icon="fa-solid:user"
            icon-color="text-purple-500"
            icon-bg-color="bg-purple-100"
          />
        </Col>
        <Col :md="6" :sm="12" :xs="24">
          <SummaryCard
            title="累计充值金额"
            :value="Number(fenToYuan(summary?.rechargePrice || 0))"
            :decimals="2"
            prefix="￥"
            icon="fa-solid:money-check-alt"
            icon-color="text-yellow-500"
            icon-bg-color="bg-yellow-100"
          />
        </Col>
        <Col :md="6" :sm="12" :xs="24">
          <SummaryCard
            title="累计消费金额"
            :value="Number(fenToYuan(summary?.expensePrice || 0))"
            :decimals="2"
            prefix="￥"
            icon="fa-solid:yen-sign"
            icon-color="text-green-500"
            icon-bg-color="bg-green-100"
          />
        </Col>
      </Row>
      <!-- 会员概览和会员终端 -->
      <Row :gutter="16">
        <Col :md="18" :sm="24" :xs="24">
          <MemberFunnelCard />
        </Col>
        <Col :md="6" :sm="24" :xs="24">
          <MemberTerminalCard />
        </Col>
      </Row>
      <!-- 会员地域分布和性别比例 -->
      <Row :gutter="16">
        <Col :md="18" :sm="24" :xs="24">
          <MemberAreaCard />
        </Col>
        <Col :md="6" :sm="24" :xs="24">
          <MemberSexCard />
        </Col>
      </Row>
    </div>
  </Page>
</template>
